<!DOCTYPE html>
<html lang="zh-CN">
    <!-- title -->


    

<!-- keywords -->



<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
    <meta name="author" content="文平夕">
    <meta name="renderer" content="webkit">
    <meta name="copyright" content="文平夕">
    
        <meta name="keywords" content="hexo,hexo-theme,hexo-blog">
    
    <meta name="description" content="">
    <meta name="description" content="Here&#39;s something encrypted, password is required to continue reading.">
<meta property="og:type" content="article">
<meta property="og:title" content="CAP理论面试考察点">
<meta property="og:url" content="https://lgsfly.gitee.io/2022/03/09/CAP/index.html">
<meta property="og:site_name" content="辄止的博客">
<meta property="og:description" content="Here&#39;s something encrypted, password is required to continue reading.">
<meta property="og:locale" content="zh_CN">
<meta property="article:published_time" content="2022-03-08T16:00:00.000Z">
<meta property="article:modified_time" content="2022-03-11T15:20:45.781Z">
<meta property="article:author" content="文平夕">
<meta name="twitter:card" content="summary">
    <meta http-equiv="Cache-control" content="no-cache">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <link rel="icon" href="/assets/myicon.ico">
    
    <title>CAP理论面试考察点 · Arbuda&#39;s Blog</title>
    <!-- /*! loadCSS. [c]2017 Filament Group, Inc. MIT License */
/* This file is meant as a standalone workflow for
- testing support for link[rel=preload]
- enabling async CSS loading in browsers that do not support rel=preload
- applying rel preload css once loaded, whether supported or not.
*/ -->
<script>
    (function (w) {
        'use strict'
        // rel=preload support test
        if (!w.loadCSS) {
            w.loadCSS = function () {}
        }
        // define on the loadCSS obj
        var rp = (loadCSS.relpreload = {})
        // rel=preload feature support test
        // runs once and returns a function for compat purposes
        rp.support = (function () {
            var ret
            try {
                ret = w.document.createElement('link').relList.supports('preload')
            } catch (e) {
                ret = false
            }
            return function () {
                return ret
            }
        })()

        // if preload isn't supported, get an asynchronous load by using a non-matching media attribute
        // then change that media back to its intended value on load
        rp.bindMediaToggle = function (link) {
            // remember existing media attr for ultimate state, or default to 'all'
            var finalMedia = link.media || 'all'

            function enableStylesheet() {
                link.media = finalMedia
            }

            // bind load handlers to enable media
            if (link.addEventListener) {
                link.addEventListener('load', enableStylesheet)
            } else if (link.attachEvent) {
                link.attachEvent('onload', enableStylesheet)
            }

            // Set rel and non-applicable media type to start an async request
            // note: timeout allows this to happen async to let rendering continue in IE
            setTimeout(function () {
                link.rel = 'stylesheet'
                link.media = 'only x'
            })
            // also enable media after 3 seconds,
            // which will catch very old browsers (android 2.x, old firefox) that don't support onload on link
            setTimeout(enableStylesheet, 3000)
        }

        // loop through link elements in DOM
        rp.poly = function () {
            // double check this to prevent external calls from running
            if (rp.support()) {
                return
            }
            var links = w.document.getElementsByTagName('link')
            for (var i = 0; i < links.length; i++) {
                var link = links[i]
                // qualify links to those with rel=preload and as=style attrs
                if (
                    link.rel === 'preload' &&
                    link.getAttribute('as') === 'style' &&
                    !link.getAttribute('data-loadcss')
                ) {
                    // prevent rerunning on link
                    link.setAttribute('data-loadcss', true)
                    // bind listeners to toggle media back
                    rp.bindMediaToggle(link)
                }
            }
        }

        // if unsupported, run the polyfill
        if (!rp.support()) {
            // run once at least
            rp.poly()

            // rerun poly on an interval until onload
            var run = w.setInterval(rp.poly, 500)
            if (w.addEventListener) {
                w.addEventListener('load', function () {
                    rp.poly()
                    w.clearInterval(run)
                })
            } else if (w.attachEvent) {
                w.attachEvent('onload', function () {
                    rp.poly()
                    w.clearInterval(run)
                })
            }
        }

        // commonjs
        if (typeof exports !== 'undefined') {
            exports.loadCSS = loadCSS
        } else {
            w.loadCSS = loadCSS
        }
    })(typeof global !== 'undefined' ? global : this)
</script>

    <style type="text/css">
    @font-face {
        font-family: 'Oswald-Regular';
        src: url("/font/Oswald-Regular.ttf");
    }

    body {
        margin: 0;
    }

    header,
    footer,
    .back-top,
    .sidebar,
    .container,
    .site-intro-meta,
    .toc-wrapper {
        display: none;
    }

    .site-intro {
        position: relative;
        z-index: 3;
        width: 100%;
        /* height: 50vh; */
        overflow: hidden;
    }

    .site-intro-placeholder {
        position: absolute;
        z-index: -2;
        top: 0;
        left: 0;
        width: calc(100% + 300px);
        height: 100%;
        background: repeating-linear-gradient(-45deg, #444 0, #444 80px, #333 80px, #333 160px);
        background-position: center center;
        transform: translate3d(-226px, 0, 0);
        animation: gradient-move 2.5s ease-out 0s infinite;
    }

    @keyframes gradient-move {
        0% {
            transform: translate3d(-226px, 0, 0);
        }
        100% {
            transform: translate3d(0, 0, 0);
        }
    }
</style>

    <link rel="preload" href="/css/style.css?v=20221112" as="style" onload="this.onload=null;this.rel='stylesheet'">
    <link rel="preload" href="/css/dark.css?v=20221112" as="style">
    <link rel="stylesheet" href="/css/dark.css">
    <link rel="stylesheet" href="/css/mobile.css?v=20221112" media="(max-width: 960px)">
    <link rel="preload" href="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.5.7/dist/jquery.fancybox.min.css" as="style" onload="this.onload=null;this.rel='stylesheet'">
    <link rel="preload" href="https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js" as="script">
    <link rel="preload" href="/scripts/main.js?v=20221112" as="script">
    <link rel="preload" href="/scripts/dark.js?v=20221112" as="script">
    <link rel="preload" href="/font/Oswald-Regular.ttf" as="font" crossorigin>
    <link rel="preload" href="https://at.alicdn.com/t/font_327081_1dta1rlogw17zaor.woff" as="font" crossorigin>
    <!-- algolia -->
    
    <!-- 百度统计  -->
    
    <!-- 谷歌统计  -->
    
<meta name="generator" content="Hexo 5.4.1"></head>

    <script src="https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js"></script>
    <script type="text/javascript">
        if (typeof window.$ == undefined) {
            console.warn('jquery load from jsdelivr failed, will load local script')
            document.write('<script src="/lib/jquery.min.js" />')
        }
    </script>
    
        <body class="post-body">
    
        <!-- header -->
        <header class="header header-mobile">
    <!-- top read progress line -->
    <div class="header-element">
        <div class="read-progress"></div>
    </div>
    <!-- sidebar menu button -->
    <div class="header-element">
        
            <div class="header-sidebar-menu">
        
            
                <div style="padding-left: 1px;">&#xe775;</div>
            
        </div>
    </div>
    <!-- header actions -->
    <div class="header-actions">
        <!-- theme mode switch button -->
        <span class="header-theme-btn header-element">
            <i class="fas fa-adjust"></i>
        </span>
        <!-- back to home page text -->
        <span class="home-link header-element">
            <a href=/>Arbuda's Studio.</a>
        </span>
    </div>
    <!-- toggle banner for post layout -->
    
        
            <div class="banner">
        
            <div class="blog-title header-element">
                <a href="/">Arbuda&#39;s Studio.</a>
            </div>
            <div class="post-title header-element">
                <a href="#" class="post-name">CAP理论面试考察点</a>
            </div>
        </div>
    
</header>

        <!-- fixed footer -->
        <footer class="footer-fixed">
    <!-- back to top button -->
    <div class="footer-fixed-element">
        
            <div class="back-top back-top-hidden">
        
        
            <div>&#xe639;</div>
        
        </div>
    </div>
</footer>

        <!-- wrapper -->
        <div class="wrapper">
            <div class="site-intro" style="







    height:50vh;

">
    
    <!-- 主页  -->
    
        
    <!-- 404页  -->
            
    <div class="site-intro-placeholder"></div>
    <div class="site-intro-img" style="background-image: url(/intro/post-bg.jpg)"></div>
    <div class="site-intro-meta">
        <!-- 标题  -->
        <h1 class="intro-title">
            <!-- 主页  -->
            
                CAP理论面试考察点
            <!-- 404 -->
            
        </h1>
        <!-- 副标题 -->
        <p class="intro-subtitle">
            <!-- 主页副标题  -->
            
                
            <!-- 404 -->
            
        </p>
        <!-- 文章页 meta -->
        
            <div class="post-intros">
                <!-- 文章页标签  -->
                
                    <div class= post-intro-tags >
    
    
</div>

                
                
                    <div class="post-intro-read">
                        <span>字数统计: <span class="post-count word-count">6</span>阅读时长: <span class="post-count reading-time">1 min</span></span>
                    </div>
                
                <div class="post-intro-meta">
                    <!-- 撰写日期 -->
                    <span class="iconfont-archer post-intro-calander">&#xe676;</span>
                    <span class="post-intro-time">2022/03/09</span>
                    <!-- busuanzi -->
                    
                        <span id="busuanzi_container_page_pv" class="busuanzi-pv">
                            <span class="iconfont-archer post-intro-busuanzi">&#xe602;</span>
                            <span id="busuanzi_value_page_pv"></span>
                        </span>
                    
                    <!-- 文章分享 -->
                    <span class="share-wrapper">
                        <span class="iconfont-archer share-icon">&#xe71d;</span>
                        <span class="share-text">Share</span>
                        <ul class="share-list">
                            <li class="iconfont-archer share-qr" data-type="qr">&#xe75b;
                                <div class="share-qrcode"></div>
                            </li>
                            <li class="iconfont-archer" data-type="weibo">&#xe619;</li>
                            <li class="iconfont-archer" data-type="qzone">&#xe62e;</li>
                            <li class="iconfont-archer" data-type="twitter">&#xe634;</li>
                            <li class="iconfont-archer" data-type="facebook">&#xe67a;</li>
                        </ul>
                    </span>
                </div>
            </div>
        
    </div>
</div>

            <script>
  // get user agent
  function getBrowserVersions() {
    var u = window.navigator.userAgent
    return {
      userAgent: u,
      trident: u.indexOf('Trident') > -1, //IE内核
      presto: u.indexOf('Presto') > -1, //opera内核
      webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核
      gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐内核
      mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否为移动终端
      ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端
      android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android终端或者uc浏览器
      iPhone: u.indexOf('iPhone') > -1 || u.indexOf('Mac') > -1, //是否为iPhone或者安卓QQ浏览器
      iPad: u.indexOf('iPad') > -1, //是否为iPad
      webApp: u.indexOf('Safari') == -1, //是否为web应用程序，没有头部与底部
      weixin: u.indexOf('MicroMessenger') == -1, //是否为微信浏览器
      uc: u.indexOf('UCBrowser') > -1, //是否为android下的UC浏览器
    }
  }
  var browser = {
    versions: getBrowserVersions(),
  }
  console.log('userAgent: ' + browser.versions.userAgent)

  // callback
  function fontLoaded() {
    console.log('font loaded')
    if (document.getElementsByClassName('site-intro-meta')) {
      document
        .getElementsByClassName('intro-title')[0]
        .classList.add('intro-fade-in')
      document
        .getElementsByClassName('intro-subtitle')[0]
        .classList.add('intro-fade-in')
      var postIntros = document.getElementsByClassName('post-intros')[0]
      if (postIntros) {
        postIntros.classList.add('post-fade-in')
      }
    }
  }

  // UC不支持跨域，所以直接显示
  function asyncCb() {
    if (browser.versions.uc) {
      console.log('UCBrowser')
      fontLoaded()
    } else {
      WebFont.load({
        custom: {
          families: ['Oswald-Regular'],
        },
        loading: function () {
          // 所有字体开始加载
          // console.log('font loading');
        },
        active: function () {
          // 所有字体已渲染
          fontLoaded()
        },
        inactive: function () {
          // 字体预加载失败，无效字体或浏览器不支持加载
          console.log('inactive: timeout')
          fontLoaded()
        },
        timeout: 5000, // Set the timeout to two seconds
      })
    }
  }

  function asyncErr() {
    console.warn('script load from CDN failed, will load local script')
  }

  // load webfont-loader async, and add callback function
  function async(u, cb, err) {
    var d = document,
      t = 'script',
      o = d.createElement(t),
      s = d.getElementsByTagName(t)[0]
    o.src = u
    if (cb) {
      o.addEventListener(
        'load',
        function (e) {
          cb(null, e)
        },
        false
      )
    }
    if (err) {
      o.addEventListener(
        'error',
        function (e) {
          err(null, e)
        },
        false
      )
    }
    s.parentNode.insertBefore(o, s)
  }

  var asyncLoadWithFallBack = function (arr, success, reject) {
    var currReject = function () {
      reject()
      arr.shift()
      if (arr.length) async(arr[0], success, currReject)
    }

    async(arr[0], success, currReject)
  }

  asyncLoadWithFallBack(
    [
      'https://cdn.jsdelivr.net/npm/webfontloader@1.6.28/webfontloader.min.js',
      'https://cdn.bootcss.com/webfont/1.6.28/webfontloader.js',
      "/lib/webfontloader.min.js",
    ],
    asyncCb,
    asyncErr
  )
</script>

            <img class="loading" src="/assets/loading.svg" style="display: block; margin: 6rem auto 0 auto; width: 6rem; height: 6rem;" />
            <div class="container container-unloaded">
                <main class="main post-page">
    <article class="article-entry">
        <div class="hbe hbe-container" id="hexo-blog-encrypt" data-wpm="Oh, this is an invalid password. Check and try again, please." data-whm="OOPS, these decrypted content may changed, but you can still have a look.">
  <script id="hbeData" type="hbeData" data-hmacdigest="62a096589ba79488b0fad50120d8ae6a2c69e36bf11785e2add7b83682f06ca3">2130ac7c1c65b9db88b07e71a36bd0386b251fddc2cdb6625c1cbc295839c7121ca4d97581365cc92c192aa6ed2ae2e767c2c79a4c812e0c8835cfac09ae9a983e13a773d2056fa7e201a4ee7018a566f41ca74e1680f5d3d6e2fd338be3109b6700d5e358f1835ef04893bdc556929f226b4ec7916ff3eda78ab95548b22833e7e43f61a506e1a5d6ac8b76c781699e4e136d967a4180e550ca2dd73c4494a1af446282af4b6d577e382cc172d0d938d196190072bead88202262840d082ddbb9f35a5fe41519c888f9f7664f49e965f4ea20b4c2202a63ba9d9413808ee0fca090d51cd1f90bd53e4450f3ef873b7525d2a66e1fb5e5f36fe9ea9e6ea129c57c04cf653042d247796b0e51c1396a949db567c7bf6609263b3af0bd7cc468684b357f217f07584375fd41bff90412f2b8e6f4d730ba921fd952eea6af6c0248c3f38e68e58630ee24a367c3aa4f3fa3c291fad8c9d56d9b656d7ce19f7dba7c4b611f02534c965b138a6a3617b76973f5009617429ad083e393c3ecf4c3a3b0e4bc66f20cb4194d3d994037a3019ed030a1a6e4930941e7bd8f1d42adf3b1d4a52adefaeff60f108984c0c27bbc27fe5729b6e66dad742b3555035f52a9efd8efad81ca50d9db279cf5326b321aa57bef20639452543b8b98bdc4df4263724499880645c3d434af34f5e719c09426876b4183ef6ac8ae2361f33b946942e2fe0642fd5d3b2a82ac76156f7e9eb6c685e7287525f97b9abc8c196b02c32571ab0fd48e93381d9c6784eda49ca1434329e1c5a37eac5346846ab383654b25820df074b1a9c11b00ba8c7fd9a97a990bfccde79575c55a0fed796ce860d028abb153c5b08ee804dc083698aa9b86487d2dbb9e391c2d4bde72fa0cc452a966482a23e6d7ef0d2e92a2bc25e173723e3ffe54a85efa28b34bcef15b1c9a6ae380096338d15e10593c9f3760937ea5e3aaea081abcbcd5bbf3261cc043c58804ecbb26b27aa0bbd22889d979fd7d462631a038f478f75b9f35c3b8a0239589046169203041b12f0968b128499e112f4db26007e5b70c31ab8b3c666ccfd95a06bc788909b79a3dd7a4ca2d74d0ca377dd78149a5b5b2b147da660775cb8dc7843a31f353cd6867169d935374996440cf89f0de180fd0bded055da2ca3640aa19d2b9b16338fe0004f25b8b04ee7d67c5052e2143e36df185278a3c2b05e23930daf7e15e338837f15664db1c4b9ed608625cbe7e7cadc8a48cf65ec12a511d54f531a5e11e57b6dc47d02d2bd89f0c32fffc1b28288c922ad49e6fc87a6d4b58f1a9f2ea1f359808c1971d0e1e3ac223f1fcf2206700b2f09b00c9a62ac39b64b4aad23e436ed0c06f611a9644a9a77fed6f726ac41d60e9f7555e3435a2d93c297c4303cf8ed330550aaf1f9a04f7dcc3429dc758319103c546308d84bc7cfcb2c7da40dcc5e416ba618e720311be25ba2c49e0964d97b1e47f81b8aa15edbc82746260a69350e30a5abfffa6572c88f847257d5d61e9b8c6153ba7de9d9ebe7f74356ff57d08496814d93244e4f4d948ac1e0ff0617c01716b8a2419009fc4fdf687dde1bb005f7ced0c0b5a91bd1ab92736b4a8166744e684a796831fde3b4299701b162da4f52cd11ad4ef67023075659e1bbc58f48d29ec6c10b735986b3f78e0cfee1ec96a7dfe50d522b830981051f9f2cbf552153a2b669f587cb2a54f1a583627942425408566c08afc2e2239817241b8f358911c571cfa8a79dc569c524adc15a4cf2ecac3a8c675a59837cdf6ad47ff9f92cbac8857e4c4bcaa1aa7d00c1ce94c9723afab45c042f3879221060f0e91e9b9e0275532c1085da10985e685bdf9f1d1fb323e14c88a5de9ee73dbc8085b38fabf24b6fd0b8da47bc45a67b5186749559e51a719b7bfd726f2858e22dd8487a8554b5d8492b17417ad8213169d6d8a362536c3617541dbc03de19c97c050d9cb70303a793df68ba6f6a6e71e9e0511084122f37e640a8c75bf685ddeda940c1c531b3e79eb55e977a118f132bb58c66ecf118ace5b7ea95cf1fb8b096cd26cbdaf0e2773f8e9a7cba67f7f0877910898cedc970df90c2ce096cb4de5815e3785c3a4bbe0d59cde2219dde20bae1ebbcd0666bf622750f0ba2c6563c2390e33d059621b4cd3aaec185c5f16d0c38b58323878164a5d49df104b4de01060eb2f30bb6b16c58def48231ff56422b06cddb5d99ee12c196704ec819e6475dab61c99e21f62d76e85fbd81f88b0cb830146b5d5e1b0c3b7ea856ba12643292a81ced8a67cf622c3113f4102ef8942b7380ae09cafdfe1d596be035dc78036a01fa6b66dc33367e0f77e54b4afef8e527c321fd05db02a93978cce3483a67fc67a165404f613ee0e1edbc1585b1d283cdd5f85a4aefd299739bb78efa25696cc54c28cff4af0c39f5516393939a8cfd025d32b201aecf4881bbba53da3ffd59d4610b158980f89e55cd44485c5fac69a105f849073dc6aee686df963b4a9bd3d02e9a12d2e94ece277fe9e7aea6def33bfa33ad67a416b294768b3587adfd28802c47b586ad36a31bcda36a05a1294cabebf1fc7b318bf4163f1fa6ae9820ec95a1fea4d303c56137c9bdfe0f1fcd57033dc3da97b899183c9f1cbfd2d45c9ec5c7b84f64a191d3df60c7557ec3c4f7ab9ee2cafa67c83bfee98e93e8730f7a2b90886829d562b646df85604c9c7f7138b90d7a6a51d23dd278b0ea51a75e3fe38a1204e869941acef7aa4bca4e41f2fe491cb728c559cb59aeb57b001e114dd2e46b3183a99eb2bc2988825b4754f47a5530ec5b87c33cdc5c40921f42402ea9ffa4ba3a87b4f6f26091ae1e889cfc8e01327fce470e41431204da717e0dc5eeaca510b411777050a07c1b4670c76d7abfaa925d63af28288f625d56ee9941723925ace074a79420b24bdc8b050ac354c0e95fde98914106bcf3e071dc2f1abd82198d4f73c97fe8e4e51d00d21e855ad8fb66771c115fb594413eedb5c3938a9437715838fd4054a586a62589da92d8da1be90ead7d2cfeaf934106febe2070e595af4f23c9ed71e231492e5709ee30570ae060d95f04d36fb545664325dfd3fc13321f1b17bb5787deda4da798d1a9e46a692dfe11e344aef5bf9fe173c07f29ec72b4b8db5bb5cbf127f5b77db29568c45de396649f4b992a78fe79f6bffccbe52cac6da77cfddcb8a1034aa8d72ec818a6f22dfb6bb45b0eaf1ca195452f0dced03f86bdc3fd60d287a33d0cda54de648d3ce3c9a1c2e0c774fd525150ecd5b3f88969bcca48cadc1311289987651fd5938eec5017c47fdc0f7bdae726ffe33ea5d2d0f39e4203ce7cfffe112d430ee25a436c2f64da1416a5e1a17be9b9792b63745090494f41dc7caa888f96db2ad5e3892250e97cadbb0fe483bb4455fcae968bdc81bbab675245db1a47024ba90214024ab5ed00f928dc27f2958640fad9ab5faafa4a1683a509683630f00ac9ab0105092c360877af0275415020bd5a143d1c981ae45a39d431758edbecaabcadbd659c9c5519a03363cbcf8c4388fd9a6af05ad29c57b6e071c8805cc891f3955c94f85254bfd49e577ecae7cd73bdb87090d73fc92084555330d2d3c045f528692d893ff1a7dd8eaa69bfb0f2a865869d63a326645c4dc3f04756757717fc98be48a48ce384fd7d4f07e68b8a94855d5130c23bb4f1bed87e8e6bc9b36be54be014e262e6205db9cb70782770d517fa02907bd9c1a079d9f85757b19c2eaf8d9af88635cefb3af627b4817acab824e49ea1ef43dcd91332d3891900f30705310c03bcda5ff467d6646b4116eeca38a9e0da9fe4164265370ee10ea095ac66946ca959db330e953fb822fa9d8ad7fca492a05e1cf29b4d3f631cdd164574f7c5c08e15bcdd881a4f6ad93869e6085c4b327d09109213ff1491704dbcad2644c9d623e05378e8b32720a741dcfddcf491dadc4796f649e3cb62551feb95dd9aeafb8683a250799b80db059456e5b55fc60993350a816ab098b47196725c5a32849443eb5d39900b0b9e80eed9b38f214fcda3e472c9dfa3455c5b1c8ff6c5d639cf5caa6186fcfd3e4c19a453e4b24ad8654f9ba8f000653872f4e68c9771815fd58cfe1d5e925a7b0dd42c8aa64c4c6eb08a2879accbe87d9d1aed3730a6bb9161b978c2d3d6ea05f0207a10cf141713375a3d919c1042162b335982d6dd997f8a1a0eb216dc473e188a813f463bd32a378d602250017e374154484d7a5fc10fd76c4e5d83b73726f6b8f0c1f0b178fbd3b61cdc8d7ba7662871c1b6cfd58580774750269da60f9ba77dc9aad44448f8d33167f83a81184a75d28c0fa471734dbfc35d1b363b761dffbaf192d7800cdd1ed8b1cf75f3fcdd9ee0db32915fa741f58a5230c20de61289c19e687a334b406df0f2f6e9317c9605db30e703fc6588deddf6be147a3529d143752d996b9b3cbde4303d8e15065e7af2cf2768560f1912890ef7e5a5403069693d973b3f00e62d03009cf36512003bdc99b2e5d618a223cdd586ccd4eb16bb426a86d9cde41002236b8c23645a975159115965826135b16996f9146071d8ca90d2aaebdf95f1369e52f98398d2677e58b8a5d80b614241087bed3e4fff2b30866e701c43264ddfaf516d49db2df6f8c3fa14202b1908870342192412dd3d5a93623166cd6fa0bc1218cb18fea584af83c4d0c60221593de76c8a22d648002e78eac19cc41a4082f760ef099601e183283820c1d4e10f364db5060d0752630b0f97d1757c421fbbfde23616d57335316ef208016bccb841de2e883201ee807b9bee99631fecc708cc3baa500711728f4567cfa9cc06fae95b7a834c14f3cb6ae5c111f85fd75870d6166e01f4c1d52cee8a251a8907fb514bbeb680b212b134cc4c06c5940a385607f96644c3e278b61a5baf6d8ede8a58ca3d0fbf880535875bec196be3f3466a0a4fb159849c25585d43eca84f0bb1376070f7448572837923ce0fbe89904914ca088e7f41fd7e630a43fed9616eabab9417b21f3b24b7cf25a1c0f7b571589d21b1e15d50264d6c9d742e575c452340e42358d50540b17eb5a39062e1372dc8c20822bcad3070f881541dcea1d5b9527f8414a6041299b3753c63ebb490f0cbbf2f530bcf5f0252a06b94ff35e3817d1762bd44e0742e8dca5b8c75fec6d4b68e48c00882406cd4a1b5d83672162082ec10a719b467245dfd17ff17058d1a302a9d715b3b214a7f1501e70188042c0ebf0f6e056da8379af57a393097f65400c6107a53edff2f98e4b76a397b453741920874ff5f6f521604c3b844e5798c383d753b6c6fa922800d56e48a1ab7a1e99e1aa06377ebee0d8e875b0739446ecb7935626bcfe488209ad3480ded3206e2af57321ec072f88668c222928dbf92d7a7b05d1ae42098751ce3c46c7d6ede1611cf3a77bd481df805b29004f0d97aba8ea6fc5378f3b2646fbc0152437e2bad90569b5df8ed59490737cf7af59573c667246a241e411ae2750f54a580a6ec7f1882e4aba713f9d528ba6b3392ef1d5d6249e8276b79cdc16b57bef10f89e3b82c5099a5e25a22308be5ebb2e7172a0a44812dc953828ce6f434359a8778dc3c5f90b054aeb8f27eab05ee68d2520a756b32c75d2b5040647e86a7fc58eaf08cfd12c3408332a150455b9d992d07f1b753b1d73228d99570d72f229aa846bb9ddf803052ecade3323f79bdc366164c0bfd0acdd0acf7c02e2739161c0f3af11c611923b00de66a2f7c99d763da73e067e5c852d62241167484baaf17a091112d6d4933fa4e66a0f70df53897cd3f57542cac43d9bd7d16d349115a816ef3df2fbe234800508efdeed34a96c9b32d57069a3bd82d61c7dfdf1d35d08417ce23265ab83c6cc5518b9cc8d6ac0e7ced674b0dfff2b9ed90ab17902ebe94839dcceb60109e9a5b31e79268c76a110445a485ab661e437bc915e98efeaa70968d11f90182002673ce81c44a99bfd855b4f964e5fac4a4e334ab8c0317a639e8b4ac3f29c28d420cfc4c284c42df54befbd97464d358ca52ddffa617eda7f37384aed63674e150d18b050b6e41c2b37426dc26a980ab33233b95bf35a7781fbe8bab0ee5511f03cebe05a160c2b55faff84d048d6f6d323dd3a1a62d020414a8fa579514adf814fbd53732193137c2082dde2ffb4819e68452e6244fb06d5193dd6dc6962d105b9675788c9af3de4009af0483c87de79427758a4456a9498da1268408ef21a0ac6b731b2717f7420c3ff26232f4d6adecc2fbce6f791d27834a3f7258a2b954dd8f59fe2c999246faaaf836bb920dbadbd063e5c7cd56d8a5bd994ad886e89aa0a8368b3f19addddc6952a8eb18beaba06f2df60fa96b798fefd79f72b267072238edd8240e48f85afc34a1e0165eacf3a2b5da5f707821bc669f48e5345bcedcd062323ee15117fe492ea557e98d9b9e762adf6cc3fce04f6740af1e10517fb1830fef11f87b6742bd902404b377dbcc382022824631a7274b638eb499d0bf3f99fbe7d140ad89d16f13509e48312cce1f168a5d16b4313a21a0be0d764d1010da5243ab354bb93351dd095cb1ed65bde626926327cd2908a1ec60ff7797244a9ec4739c2afd93ccfc4b57bb4da5c99ba37d0deaee82a1c5f199ee033a1a8abc132766b8c9de73c39a6f308694635b3985aeccc6465615b6d5bc8a81fa9737bc3ef31e34f488a32a2d4d78136de4d9a912c8d685870d833abed9b2ebb058829aaa99401e6d6608c548e6b6d77bf377b4abe56b5a0c520886f06c54ceb3b22905e20ef54f9cb1cf4d078a05bac9a0907cdc637c2f54e73180fe62d8018440cd813a673f542fcad16e19e8089cc3fb50651208f33d87348f095388ed67616cb24026166681fc47a55db1cd949726617ebc3cf19b0a22f367f435b038dd918158a4a327fad6f96c26d661c3b22883f0aed5b153f5e0fcf3edb0034414a675e9591f241cbbfa704dcad668037ac31116c444d1f3498e278cb7e3dbdf5a9d58f1addba3815c1900ba46289273165a202f2a20dea7372067faf65ab0bc9c20a51caeb0c99fefa6bef36e89325c29ebdefd7ea1e19ddbd0729299b1acd938c09d757d9b972d7ae3720de358ac7c1919b1f04e5ff7da8324b3fffb76a63945c6ee49b715ec2da7037220df8dcb00d09ed426aacaee5aea001b30ed5d7ff60529b36be680f4bdeaa7cb61ea3f9eef22322401f64f4431b7b7c43e50e52f3f7062ecaf7a21bd6e8c5fe01642268d7ecad8c933e855dbfd1e1a1cb21a324fc370acc5943ff0d5476081537926a81d680045437a4127d7469754a8c3090f4d18935f3cf3a81d437ebf75c150279bd2acb18ae3cb5d7c68c4b16371ef87eab1fb6d4729eac2dbc220c85042c8cc84fae02ec51f890f100c46a53a9e55b03d288fe71c31ce3f27232c87a25400871ac1a5753e680ae97b3895929a827f0476df1d757898882b76526ab66faae387b05f31820ba71668b8a3fbf206b31eceba3cc63692b73aeb6dc6c8e4014fc531adb2c7b1eed3bd319788e628f00f33941ca81161d7a4f786d5a79940760172c954519e2398476e65290895b0c20915a886751999ee2f0ad86b1307dc8f3cc014514d120aeb1bdd25f39568b659d8cf7d4a74d0ef5fe284e02bc53909b523afcde0b9c67f4c8e5ab25da7522fd8a74bc57bc1d405024b1ad878dbf0ccfe9aae558db5284dd9ddae8da405448742a0619dea7e2afc12951c8cd012791f6809c393fec80807328e8c484a9bfabd6f8bdbc5c8a7c0d7af7e837442644a68bd7f99ea4fa27d59e70cbc6517959c9cc7d6c11a3655da922e807efb27c0edd346295421bb67195f378ce8a28a5846090d667d73b9d62bfe43bbe33728e0e4d5a998746632200739181594208b821161cc2708c1d7fa8e8877efb5b4a70d7ad6a67539935649738259879cf81f218a2697a60316535dc03c88d6abc93b3a3373a7e5a692a7b0f95d58b4ce51270c7489a1b43710bf71143223fb1f81ea209c08dae784e1e084f540a772303a380f13a437134398cfd1e6e7c207cbd7902f612cba01f790453840546985ca226bf14363c0290c1</script>
  <div class="hbe hbe-content">
    <div class="hbe hbe-input hbe-input-default">
      <input class="hbe hbe-input-field hbe-input-field-default" type="password" id="hbePass">
      <label class="hbe hbe-input-label hbe-input-label-default" for="hbePass">
        <span class="hbe hbe-input-label-content hbe-input-label-content-default">Hey, password is required here.</span>
      </label>
    </div>
  </div>
</div>
<script data-pjax src="/lib/hbe.js"></script><link href="/css/hbe.style.css" rel="stylesheet" type="text/css">
    </article>
    <!-- license -->
    
        <div class="license-wrapper">
            <p>原文作者：<a href="https://lgsfly.gitee.io">文平夕</a>
            <p>原文链接：<a href="https://lgsfly.gitee.io/2022/03/09/CAP/">https://lgsfly.gitee.io/2022/03/09/CAP/</a>
            <p>发表日期：<a href="https://lgsfly.gitee.io/2022/03/09/CAP/">March 9th 2022, 12:00:00 am</a>
            <p>更新日期：<a href="https://lgsfly.gitee.io/2022/03/09/CAP/">March 11th 2022, 11:20:45 pm</a>
            <p>版权声明：本文采用<a rel="license noopener" target="_blank" href="http://creativecommons.org/licenses/by-nc/4.0/">知识共享署名-非商业性使用 4.0 国际许可协议</a>进行许可</p>
        </div>
    
    <!-- paginator -->
    <ul class="post-paginator">
        <li class="next">
            
                <div class="nextSlogan">Next Post</div>
                <a href="/2022/04/01/%E4%BA%BA%E9%97%B4%E5%9B%9B%E6%9C%88%E5%A4%A9/" title="人间四月天">
                    <div class="nextTitle">人间四月天</div>
                </a>
            
        </li>
        <li class="previous">
            
                <div class="prevSlogan">Previous Post</div>
                <a href="/2022/03/05/hello-world/" title="Hello World">
                    <div class="prevTitle">Hello World</div>
                </a>
            
        </li>
    </ul>
    <!-- comment -->
    
        <div class="post-comment">
            <!-- 来必力 City 版安装代码 -->


            

            

            

            <!-- utteranc评论 -->


            <!-- partial('_partial/comment/changyan') -->
            <!--PC版-->


            
            

            

        </div>
    
    <!-- timeliness note -->
    <!-- idea from: https://hexo.fluid-dev.com/posts/hexo-injector/#%E6%96%87%E7%AB%A0%E6%97%B6%E6%95%88%E6%80%A7%E6%8F%90%E7%A4%BA -->
    
    <!-- Mathjax -->
    
</main>

                <!-- profile -->
                
            </div>
            <footer class="footer footer-unloaded">
    <!-- social  -->
    
        <div class="social">
            
    
        
            
                <a href="mailto:123456@qq.com" class="iconfont-archer email" title=email ></a>
            
        
    
        
            
                <a href="//github.com/lgsfly" class="iconfont-archer github" target="_blank" title=github></a>
            
        
    
        
            
                <span class="iconfont-archer wechat" title=wechat>
                    
                    <img class="profile-qr" src="/assets/qr_code.jpg" />
                </span>
            
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    
        
    


        </div>
    
    <!-- powered by Hexo  -->
    <div class="copyright">
        <span id="hexo-power">Powered by <a href="https://hexo.io/" target="_blank">Hexo</a></span><span class="iconfont-archer power">&#xe635;</span><span id="theme-info">theme <a href="https://github.com/fi3ework/hexo-theme-archer" target="_blank">Archer</a></span>
    </div>
    <!-- website approve for Chinese user -->
    
    <!-- 不蒜子  -->
    
        <div class="busuanzi-container">
            
             
                <span id="busuanzi_container_site_pv">PV: <span id="busuanzi_value_site_pv"></span> :)</span>
            
        </div>
    	
</footer>

        </div>
        <!-- toc -->
        
            <div class="toc-wrapper toc-wrapper-loding" style=







    top:50vh;

>
                <div class="toc-catalog">
                    <span class="iconfont-archer catalog-icon">&#xe613;</span><span>CATALOG</span>
                </div>
                
            </div>
        
        <!-- sidebar -->
        <div class="sidebar sidebar-hide">
    <ul class="sidebar-tabs sidebar-tabs-active-0">
        <li class="sidebar-tab-archives"><span class="iconfont-archer">&#xe67d;</span><span class="tab-name">Archive</span></li>
        <li class="sidebar-tab-tags"><span class="iconfont-archer">&#xe61b;</span><span class="tab-name">Tag</span></li>
        <li class="sidebar-tab-categories"><span class="iconfont-archer">&#xe666;</span><span class="tab-name">Cate</span></li>
    </ul>
    <div class="sidebar-content sidebar-content-show-archive">
        <div class="sidebar-panel-archives">
    <!-- 在 ejs 中将 archive 按照时间排序 -->
    
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
    
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
        
    
    
    
    
    <div class="total-and-search">
        <div class="total-archive">
        Total : 8
        </div>
        <!-- search  -->
        
    </div>
    
    <div class="post-archive">
    
        
            
            
            <div class="archive-year"> 2023 </div>
            <ul class="year-list">
            
        
        <li class="archive-post-item">
            <span class="archive-post-date">03/07</span>
            <a class="archive-post-title" href="/2023/03/07/%E5%B9%B4%E5%88%9D%E6%80%BB%E7%BB%93/">年初总结</a>
        </li>
    
        
        <li class="archive-post-item">
            <span class="archive-post-date">03/03</span>
            <a class="archive-post-title" href="/2023/03/03/%E9%9A%8F%E7%AC%94%E4%B8%80/">随笔一</a>
        </li>
    
        
            
            
                
                </ul>
            
            <div class="archive-year"> 2022 </div>
            <ul class="year-list">
            
        
        <li class="archive-post-item">
            <span class="archive-post-date">11/11</span>
            <a class="archive-post-title" href="/2022/11/11/Centos7Wifi/">CentOS7连接Wifi</a>
        </li>
    
        
        <li class="archive-post-item">
            <span class="archive-post-date">04/15</span>
            <a class="archive-post-title" href="/2022/04/15/SelfVVn/">SelfVVN</a>
        </li>
    
        
        <li class="archive-post-item">
            <span class="archive-post-date">04/01</span>
            <a class="archive-post-title" href="/2022/04/01/%E4%BA%BA%E9%97%B4%E5%9B%9B%E6%9C%88%E5%A4%A9/">人间四月天</a>
        </li>
    
        
        <li class="archive-post-item">
            <span class="archive-post-date">03/09</span>
            <a class="archive-post-title" href="/2022/03/09/CAP/">CAP理论面试考察点</a>
        </li>
    
        
        <li class="archive-post-item">
            <span class="archive-post-date">03/05</span>
            <a class="archive-post-title" href="/2022/03/05/hello-world/">Hello World</a>
        </li>
    
        
        <li class="archive-post-item">
            <span class="archive-post-date">03/05</span>
            <a class="archive-post-title" href="/2022/03/05/2022-03-05-%E5%BC%80%E7%AF%87/">开篇</a>
        </li>
    
    </div>
</div>

        <div class="sidebar-panel-tags">
    <div class="sidebar-tags-name">
        
            <span class="sidebar-tag-name" data-tags="操作系统">
                <span class="iconfont-archer">&#xe606;</span>
                操作系统
            </span>
        
            <span class="sidebar-tag-name" data-tags="随笔">
                <span class="iconfont-archer">&#xe606;</span>
                随笔
            </span>
        
    </div>
    <div class="iconfont-archer sidebar-tags-empty">&#xe678;</div>
    <div class="tag-load-fail" style="display: none; color: #ccc; font-size: 0.6rem;">
        缺失模块，请参考主题文档进行安装配置：https://github.com/fi3ework/hexo-theme-archer#%E5%AE%89%E8%A3%85%E4%B8%BB%E9%A2%98
    </div> 
    <div class="sidebar-tags-list"></div>
</div>

        <div class="sidebar-panel-categories">
    <div class="sidebar-categories-name">
    
        <span class="sidebar-category-name" data-categories="随笔">
            <span class="iconfont-archer">&#xe60a;</span>
            随笔
        </span>
    
    </div>
    <div class="iconfont-archer sidebar-categories-empty">&#xe678;</div>
    <div class="sidebar-categories-list"></div>
</div>

    </div>
</div>

        <!-- site-meta -->
        <script>
    var siteMetaRoot = "/"
    if (siteMetaRoot === "undefined") {
        siteMetaRoot = '/'
    }
    var siteMeta = {
        url: "https://lgsfly.gitee.io",
        root: siteMetaRoot,
        author: "文平夕"
    }
</script>

        <!-- import experimental options here -->
        <!-- Custom Font -->


        <!-- main func -->
        <script src="/scripts/main.js?v=20221112"></script>
        <!-- dark mode -->
        <script src="/scripts/dark.js?v=20221112"></script>
        <!-- fancybox -->
        <script src="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.5.7/dist/jquery.fancybox.min.js" defer></script>
        <!-- algolia -->
        
        <!-- busuanzi -->
        
            <script src="//busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js" async></script>
        
        <!-- CNZZ -->
        
        <!-- async load share.js -->
        
            <script src="/scripts/share.js?v=20221112" async></script>
        
        <!-- mermaid -->
        
    </body>
</html>
